package hot;

/**
 * @author lakersUp
 * @Classname
 * @Description
 * @Date 2022/3/8 14:47
 * @Version 1.0
 */
public class Hot10isMatch {
    public boolean isMatch(String s, String p) {
        if(p==""){
            return s=="";
        }
        int m=s.length();
        int n=p.length();
        boolean[][] dp=new boolean[m+1][n+1];
        dp[0][0]=true;
        // i=0, j=1
        for(int i=0;i<=m;i++){
            for(int j=1;j<=n;j++){
                if(p.charAt(j-1)=='*'){
                    if(myIsMatch(s,p,i,j-1)){
                        dp[i][j]=dp[i-1][j] || dp[i][j-2];
                    }else {
                        dp[i][j]=dp[i][j-2];
                    }
                }else {
                    // 不为* ,传入的是j
                    if(myIsMatch(s,p,i,j)){
                        dp[i][j]=dp[i-1][j-1];
                    }
                }
            }
        }
        return dp[m][n];
    }

    private boolean myIsMatch(String s, String p, int i, int j) {
        if(i==0){
            return false;
        }
        if(p.charAt(j-1)=='.'){
            return true;
        }
        return s.charAt(i-1)==p.charAt(j-1);
    }
}
